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FEATURES 


@ Four independently programmable counter/timer 
channels, each with a readable downcounter and a 
selectable 16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 


m Selectable positive or negative trigger initiates timer 
operation. 


@ Three channels have Zero Count/Timeout outputs 


capable of driving Darlington transistors. (1.5 mV @ 1.5V) 
@ NMOS version for cost sensitive performance solutions. 


m= CMOS version for the designs requiring low power 
consumption 


mw NMOS Z0843004 - 4 MHz, 20843006 - 6.17 MHz. 
@ CMOS Z84C3006 - DC to 6.17 MHz, 284C3008 - 
8 MHz, Z84C3010 - DC to 10 MHz 


w interfaces directly to the Z80 CPU or—for baud rate 
generation—to the 280 SIO. 


DC to 


a Standard Z80 Family daisy-chain interrupt structure 
provides fully vectored, prioritized interrupts without 
external logic. The CTC may also be used as an interrupt 
controller. 


® 6 MHz version supports 6.144 MHz CPU clock opera- 
tion. 





GENERAL DESCRIPTION 


The Z80 CTC, hereinafter referred to as Z80 CTC or CTC, 
four-channel counter/timer can be programmed by system 
software for a broad range of counting and timing appfica- 
tions. The four independently programmable channels of 
the Z80 CTC satisfy common microcomputer system re- 
quirements for event counting, interrupt and interval timing, 

and general clock rate generation. 


System design is simplified because the CTC connects 
directly to both the Z80 CPU and the 280 SIO with no 
additional logic. In larger systems, address decoders and 
buffers may be required. 
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Programming the CTC is straightforward: each channel is 


programmed with two bytes; a third is necessary when 


interrupts are enabled. Once started, the CTC counts down, 
automatically reloads its time constant, and resumes 
counting. Software timing loops are completely eliminated. 
Interrupt processing is simplified because only one vector 
need be specified; the CTC internally ables a unique 
vector for each channel. 


The Z80 CTC requires asingle +5%V power supply andithe 
standard Z80 single-phase system clock. Itis packaged in 
28-pin DIPs, a44-pin plastic chip carrier, anda 44-pin LQFP 

(Figures 2a, 2b, and 2c). Note that the LOQFP 
package is only available for CMOS. versions. 
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Figure 2b. 44-pin Chip Cartier, Pin Assignments 





FUNCTIONAL DESCRIPTION 


The Z80 CTC has four independent counter/timer channels. 
Each channel is individually programmed with two words: a 
control] word and a time-constant word. The control word 
selects the operating mode (counter or timer), enables or 
disables the channel! interrupt, and selects certain other 
operating parameters. If the timing mode is selected, the 
control word also sets a prescaler, which divides the system 
clock by either 16 or 256. The time-constant word is a value 
from 1 to 256. 


During operation, the individual counter channel counts 
down from the preset time constant value. In counter mode 
operation the counter decrements on each of the CLK/TRG 
input pulses until Zero count is reached. Each decrement is 
synchronized by the system clock. For counts greater than 
256, more than one counter can be cascaded. At zero 
count, the down-counter is automatically reset with the time 
constant value. 


The timer mode determines time intervals as small as 2 
pts(8 MHz), 3 xs (6 MHz), or 4 2s (4MHz) without additional 
logic or software timingloops. Time intervals are generated 
by dividing the system clock with a prescaler that decre- 
ments a preset down-counter. 





INTERNAL STRUCTURE 


The CTC has four major elements, as shown in Figure 3. 
m CPU bus I/O 

@ Channel control logic 

@ Interrupt logic 

@ Counter/timer circuits 


CPU Bus I/O. The CPU bus I/O circuit decodes the address 
inputs, and interfaces the CPU data and control signals to 
the CTC for distribution on the internal bus. 
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Thus, the time interval is an integral multiple of the clock 
period, the prescaler value (16 or 256), and the time 
constant that is preset-in the down-counter. A timer is 
triggered automatically when its time constant value is 
programmed, or by an external CLK/TRG input. 


Three channels have two outputs that occur at zero count. 
The first output is a zero-count/timeout pulse at the ZC/TO 
output. The fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt request is the only output available 
from Channel 3. 


The second output is Interrupt Request (INT), which occurs 
ifthe channef has its interrupt enabled during programming. 
When the Z80 CPU acknowledges Interrupt Request, the 
Z80 CTC places an interrupt vector on the data bus. 


The four channels of the Z80 CTC are fully prioritized and fit 
into four contiguous slots in a standard Z80 daisy-chain 
interrupt structure. Channel 0 is the highest priority and 
Channel 3 the lowest. Interrupts can be individually enabled 
(or disabled) for each of the four channels. 


Internal Control Logic. The CTC internal control logic 
controls overall chip operating functions such as the chip 
enable, reset, and read/write logic. 


Interrupt Logic. The interrupt control logic ensures that the 
CTC interrupts interface properly with the Z80 CPU interrupt 
system. The logic controls the interrupt priority of the CTC as 
a function of the IEI signal. If Elis High, the CTC has priority. 
During interrupt processing, the interrupt logic holds IEO 
Low, which inhibits the interrupt operation on lower priority 
devices. If the IEI input goes Low, priority is relinquished 
and the interrupt logic drives IEO Low. 
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Figure 3. Functional Block Diagram 


If a channel is programmed to request an interrupt, the 
interrupt logic drives IEO Low at the zero count, and 
generates an INT signal to the 280 CPU. When the Z80 CPU 
responds with interrupt acknowledge (M1 and IORQ), then 
the interrupt logic arbitrates the CTC internal priorities, and 
the interrupt control logic places a unique interrupt vector on 
the data bus. 





If an interrupt is pending, the interrupt logic holds IEO Low. 
When the Z80 CPU issues a Return From interrupt (RET!) 
instruction, each peripheral device decodes the first byte 
(ED4¢). If the device has a pending interrupt, it raises IEO 
(High) for one M1 cycle. This ensures that all lower priority 
devices can decode the entire RET! instruction and reset 


properly. 
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Figure 4. Counter/Timer Block Diagram 
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Counter/Timer Circuits. The CTC has four independent 
counter/timer circuits, each containing the logic shown in 
Figure 4. 


Channel Control Logic. The channel control logic 
receives the 8-bit channel control word when the 
counter/timer channel is programmed. The channel control 
logic decodes the control word and sets the following 
operating conditions: 


@ Interrupt enable (or disable) 

m Operating mode (timer or counter) 

@ Timer mode prescaler factor (16 or 256) 

m Active slope for CLK/TRG input 

@ Timer mode trigger (automatic or CLK/TRG input) 
@ Time constant data word to follow 

@ Software reset 


Time Constant Register. When the counter/timer channel 
is programmed, the time constant register receivas and 
stores an 8-bit time constant value, which can be anywhere 
from 1 to 256 (0 = 256). This constant is automatically 
loaded into the down-counter when the countet/timer 
channel is initialized, and subsequently after each zero 
count. 


Prescaler. The prescaler, which is used only in timer mode, 
divides the system clock frequency by a factor of either 16 or 
256. The prescaler output clocks the down-counter during 
timer operation. The effect of the prescaler an the 
down-counter is a multiplication of the system clock period 
by 16 or 256. The prescaler factor is programmed by bit 5 of 
the channel control word. 
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Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant register 
contents. The counter is then decremented one of two ways, 
depending on operating mode: 


m By the prescaler output (timer mode) 


m By the trigger pulses into the CLK/TRG input (counter 
mode) 





PROGRAMMING 


Each Z80 CTC channel must be programmed pnior to 
operation. Programming consists of writing two words to the 
(/O port that corresponds to the desired channel. The first 
word is a control word that selects the operating mode and 
other parameters; the second word is atime constant, which 
is a binary data word with a value from 1 to 256. A time 
constant word must be preceded by a channel control word. 


After initialization, channels may be reprogrammed at any 
time. If updated control and time constant words are written 
to a channel during the count operation, the count 
continues to zero before the new time constant is loaded into 
the counter. 


lf the interrupt on any Z80 CTC channel is enabled, the 
programming procedure should also include an interrupt 
vector. Only one vector is required for all four channels, 
because the interrupt logic automatically modifies the vector 
for the channel requesting service. 


A control word is identified by a 1 in bit. A 1 in bit 2 indicates 
atime constant word is to follow. Interrupt vectors are always 
addressed to Channel 0, and identified by a 0 in bit 0. 


Addressing. During programming, channels are 
addressed with the channel! select pins CS; and CSp. A 2-bit 
binary code selects the appropriate channel as shown in the 
following table. 


Leal 


Without disturbing the down-count, the 280 CPU can read 
the count remaining at any time by performing an I/O read 
operation at the port address assigned to the CTC channel. 
When the down-counter reaches the zero count, the ZC/TO 
output generates a positive-going pulse. When the interrupt 
is enabled, zero count also triggers an interrupt request 
signal (INT) from the interrupt logic. 





Reset. The CTC has both hardware and software resets. 
The hardware reset terminates all down-counts and disables 
all CTC interrupts by resetting the interrupt bits in the contro! 
registers. In addition, the ZC/TO and Interrupt outputs go 
inactive, IEO reflects IE!l, and Dg-D7 go to the 
high-impedance state. All channels must be completely 
reprogrammed after a hardware reset. 


The software reset is controlled by bit 1 in the channel 
control word. When a channel receives a software reset, it 
stops counting. When a software reset is used, the other bits 
in the control word also change the contents of the channel 
control register. After a software reset a new time constant 
word must be written to the same channel. 


lf the channel control word has both bits 0; and Do ¢et to 1, 
the addressed channel stops operating, pending a new time 
constant word. The channel is ready to resume after the new 
constant is programmed. In timer mode, if D3 = QO, 
operation is triggered automatically when the time constant 
word is loaded. 


Channel Control Word Programming. The channel 
control word is shown in Figure 5. it sets the modes and 
parameters described below. 


Interrupt Enable. D7 enables the interrupt, so that an 
interrupt output (INT) is generated at zero count. Interrupts 
may be programmed in either mode and may be enabled or 
disabled at any time. 


Channel! CS, CSo 
0 0 0 Mode. Dg selects either timer or counter operating mode. 
1 0 1 Prescaler Factor. (Timer Mode Only). Ds selects 
2 1 0 factor—either 16 or 256. 
3 1 1 
[D7 | Dg [Os | Dy | Ds [Dz [Ds | Do 
INTERRUPT J L CONTROL OR VECTOR 


1 ENABLES INTERRUPT 
- 0 DISABLES INTERRUPT 


MODE 
0 SELECTS TIMER MODE 
1 SELECTS COUNTER MODE 


PRESCALER VALUE * 
1 = VALUE OF 256 
0 = VALUE OF 16 


CLK/TAG EDGE SELECTION 
0 SELECTS FALLING EDGE 
1 SELECTS RISING EDGE 


0 = VECTOR 
1 = CONTROL WORD 


RESET 
0 = CONTINUED OPERATION 
4 = SOFTWARE RESET 


TIME CONSTANT 
0 = NO TIME CONSTANT FOLLOWS 
1 = TIME CONSTANT FOLLOWS 


TIMER TRIGGER* 

0 = AUTOMATIC TRIGGER WHEN 
TIME CONSTANT IS LOADED 

1 = CLK/TRG PULSE STAATS TIMER 


“TIMER MODE ONLY 


Figure 5. Channel Control Word 
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Clock/Trigger Edge Selector. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during operation is 
equivalent to issuing an active edge. If the trigger slope is 
changed by a control word update while a channel is 
pending operation in timer mode, the result is the same as a 
CLK/TRG pulse and the timer starts. Similarly, if the channel 
is in counter mode, the counter decrements. 


Timer Trigger (Timer Mode Only). D3 selects the trigger 
mode for timer operation. When D3 is reset to 0, the timer is 
triggered automatically. The time constant word is 
programmed during an I/O write operation, which takes one 
machine cycle. At the end of the write operation there is a 
setup delay of one clock period. The timer starts 
automatically (decrements) on the rising edge of the second 
Clock pulse (Tz) of the machine cycle following the write 
operation. Once started, the timer runs continuously. At zero 
count the timer reloads automatically and continues 
counting without interruption or delay, until stopped by a 
reset. 


When Ds is set to 1, the timer is triggered externally through 
the CLK/TRG input. The time constant word is programmed 
during an '/O write operation, which takes one machine 
cycle. The timer is ready for operation on the rising edge of 
the second clock pulse (T2) of the following machine cycle. 
Note that the first timer decrement follows the active edge of 
the CLK/TRG pulse by a delay time of one clock cycle if a 
minimum setup time to the rising edge of clock is met. If this 
minimum is not met, the delay is extended by another clock 
period. Consequently, for immediate triggering, the 
CLK/TRG input must precede To by one clock cycle plus its 
minimum setup time. If the minimum time is not met, the 
timer will start on the third clock cycle (T3). 


Once started the timer operates continuously, without 
interruption or delay, until stopped by a reset. 


Time Constant. A 1 in Do indicates that the next word 
addressed to the selected channel is a time constant data 
word for the time constant register. The time constant word 
may be written at any time. 


A 0 in Dg indicates no time constant word is to follow. This is 
ordinarily used when the channel is already in operation and 
the new channel control word is an update. A channel will 


Figure 6. Time Constant Word 
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not operate without a time constant value. The only way to 
write a time constant value is to write a control word with Do 
set. 


Software Reset. Setting D; to 1 causes a software reset, 
which is described in the Reset section. 


Control! Word. Setting Dp to 0 identifies the word as a control 
word. 


Time Constant Programming. Before a channel can start 
counting it must receive atime constant word from the CPU. 
During programming or reprogramming, a channel contro! 
word in which bit 2 is set must precede the time constant 
word to indicate that the next word is a time constant. The 
time constant word can be any value from 1 to 256 (Figure 
6). Note that 004. is interpreted as 256. 


in timer mode, the time interval is controlled by three factors: 
m The system clock period (CLK) 


m The prescaler factor (P), which multiplies the interval by 
either 16 or 256 


w Thetime constant (1), which is programmed into the time 
constant register 


Consequently, the time interval is the product of CLK x P x T. 
The minimum timer resolution is 16 x CLK (4us with a 4MHz 
clock). The maximum timer interval is 256 x CLK x 256 
(16.4 ms with a4MHz clock). For longer intervals timers may 
be cascaded. 


interrupt Vector Programming. If the Z80 CTC has one or 
more interrupts enabled, it can supply interrupt vectars to 
the Z80 CPU. To do so, the Z80 CTC must be 
pre-programmed with the most-significant five bits of the 
interrupt vector. Programming consists of writing a vector 
word to the 1/O port corresponding to the Z80 CTC Channel 
0. Note that Dp of the vector word is always zero, to 
distinguish the vector from a channel control word. D; and 
Dz are not used in programming the vector word. Thes¢ bits 
are supplied by the interrupt logic to identify the channel 
requesting interrupt service with a unique interrupt vector 
(Figure 7). Channel 0 has the highest priority. 
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0 
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Figure 7. Interrupt Vector Word 
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PIN DESCRIPTION 


CE. Chip Enable (input, active Low). When enabled the CTC 
accepts control words, interrupt vectors, or time constant 
data words from the data bus during an I/O write cycle; or 
transmits the contents of the downcounter to the CPU during 
an I/O read cycle. In most applications this signal is 
decoded from the eight least significant bits of the address 
bus for any of the four I/O port addresses that are mapped to 
the four counter-timer channels. 7 


CLK. System Clock (input). Standard single-phase Z80 
system clock. 


CLK/TRGp-CLK/TRG3. External Clock/Timer Trigger 
(input, user-selectable active High or Low). Four pins 
corresponding to the four Z80 CTC channels. In counter 
mode, every active edge on this pin decrements the 
downcounter. in timer mode, an active edge starts the timer. 


CSy-CS;. Channel Select (inputs active High). Two-bit 
binary address code selects one of the four CTC channels 
for an I/O write or read (usually connected to Ag and Aj). 


SYSTEM 
BUSES 





Figure 8. A Typical Z80 Environment 





Do-D7. System Data Bus (bidirectional, 3-state). Transfers all 
data and commands between the Z80 CPU and the Z80 
CTC. 


1El. interrupt Enable In (input, active High). A High indicates 
that no other interrupting devices of higher priority in the 
daisy chain are being serviced by the Z80 CPU. 


IEO. Interrupt Enable Out (output, active High). High only if 
[El is High and the Z80 CPU is not servicing an interrupt 
from any Z80 CTC channel. IEO blocks lower. priority 
devices from interrupting while a higher priority interrupting 
device is being serviced. 


INT. interrupt Request (output, open drain, active Low). Low 
when any Z80 CTC channel! that has been programmed to 
enable interrupts as a zero-count condition in its 
downcounter. 


tORQ. /nput/Output Request (input from CPU, active Low). 
Used with CE and RD to transfer data and channel contro! 
words between the Z80 CPU and the Z80 CTC. During a 
write cycle, IORQ and CE are active and RD inactive. The 
Z80 CTC does not receive a specific write signal; rather, it 
internally generates is own from the inverse of an active RD 
signal. In a read cycle, IORQ, CE, and RD are aative; the 
contents of the downcounter are read by the 280 CPU. If 
IORQ and Mi are both true, the CPU is acknowledging an 
interrupt request, and the highest priority interrupting 
channel places its interrupt vector on the 280 data bus. 








M1. Machine Cycle One (input from CPU, active Low). 
When M1 and IORQ are active, the Z80 CPU is 
acknowledging an interrupt. The Z80 CTC then places an 
interupt vector on the data bus if it has highest priority, and if 


~ achannel has requested an interrupt (N17). 


RD. Read Cycle Status (input, active Low). Used in | 





conjunction with IORQ and CE to transfer data and channel 
control words between the Z80 CPU and the Z80 CTC. 


RESET. Reset (input active Low). Terminates all 
down-counts and disables all interrupts by resetting the 
interrupt bits in all control registers; the ZC/TO and the 
interrupt outputs go inactive; IEO reflects IE1; Do-D7 go to the 
high-impedance state. 


ZC/TOp-ZC/TO2. Zero Count/Timeout (output. active 
High). Three ZC/TO pins corresponding to 280 CTC 
channels 2 through 0 (Channel 3 has no ZC/TO pin). In both 
counter and timer modes the output is an active High pulse 
when the downcounter decrements to zero. 
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TIMING 


Read Cycle Timing. Figure 9 shows read cycle timing. This 
cycle reads the contents of a down-counter without 
disturbing the count. During clock cycle To, the Z80 CPU 
initiates a read cycle by driving the following inputs Low: RD, 
lIORQ, and CE. A 2-bit binary code at inputs CS; and CS 
selects the channel to be read. M1 must be High to 
distinguish this cycle from an interrupt acknowledge. 


T Ta Twa T3 Th 


1ORQ \ / 





DATA OUT 
Figure 9. Read Cycle Timing 


Write Cycle Timing. Figure 10 shows write cycle timing for 
loading control, time constant, or vector words. 


The CTC does not have a write signal input, so it generates 
one internally when the read (RD) input is High during T3. 
During Tz (ORQ and CE inputs are Low. M1 must be High to 
distinguish a write cycle from an interrupt acknowledge. A 
2-bit binary code at inputs CS; and CSq selects the channel 
to be addressed, and the word being written is placed on the 
280 data bus. The data word is latched into the appropriate 
register with the rising edge of clock cycle T3. 
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1ORQ \ / 





Figure 10. Write Cycle Timing 
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Timer Operation. In the timer mode, a CLK/TRG'‘ pulse 
input starts the timer (Figure 11) on the second succeeding 
rising edge of CLK. The trigger pulse is asynchronous, and 
it must have a minimum width. A minimum lead time (210 ns) 
is required between the active edge of the CLK/TRG and the 
next rising edge of CLK to enable the prescaler on the 
following clock edge. If the CLK/TRG edge occurs closer 
than this, the initiation of the timer function is delayed one 
clock cycle. This corresponds to the start-up timing 
discussed in the programming section. The timer can also 
be started automatically if so programmed by the channel! 
control word. 


CLK/TRG 


INTERNAL 
TIMER 


START TIMING 





Figure 11. Timer Mode Timing 


Counter Operation. In the counter mode, the CLK/TRG 
pulse input decrements the downcounter. The trigger is 
asynchronous, but the count is synchronized with CLK. For 
the decrement to occur on the next rising edge of CLK, the 
trigger edge must precede CLK by a minimum lead tirne as 
shown in Figure 12. If the iead time is less than specified, the 
count is delayed by one clock cycle. The trigger pulsa must 
have a minimum width, and the trigger period must be at 
least twice the clock period. If the trigger repetition tate is 
faster than v3 the clock frequency, then TsCTR(Cs), AC 
Characteristics Specification 26, must be met. 


The ZC/TO output occurs immediately after zero count, and 
follows the rising CLK edge. 
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Figure 12. Counter Mode Timing 
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INTERRUPT OPERATION 


The Z80 CTC follows the Z80 system interrupt protocol for 
nested priority interrupts and return from interrupt, wherein 
the interrupt priority of a peripheral is determined by its 
location in a daisy chain. Two lines—IEI and |EO—in the CTC 
connect it to the system daisy chain. The device closest to 
the +5V supply has the highest priority (Figure 13). For 
additional information on the Z80 interrupt structure, refer to 
the Z80 CPU Product Specification and the Z80 CPU 
Technical Manual. | 


HIGHEST PRIORITY 
DEVICE 


LOWEST PRIORITY 


DEVICE 
DEVICE 1 DEVICE 3 


HI HI Ht 


DEVICE 2 


Figure 13. Daisy-Chain Interrupt Priorities 


a 


Within the Z80 CTC, interrupt priority is predetermined by 
channel number: Channel 0 has the highest priority, and 
Channe! 3 the lowest. If a device or channel is being 
serviced with an interrupt routine, it cannot be interrupted by 
a device or channel with lower priority until service is 
complete. Higher priority devices or channels may interrupt 
the servicing of lower priority devices or channels. 


A Z80 CIC channel may be programmed to request an 
interrupt every time its downcounter reaches zero. Note that 
the CPU must be programmed for interrupt mode 2. Some 
time after the interrupt request, the CPU sends an interrupt 
acknowiedge. The CTC interrupt control logic determines 
the highest priority channel that is requesting an interrupt. 
Then, if the CTC tEl input is High (indicating that it has 
priority within the system daisy chain) it places an 8-bit 
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DATA VECTOR 


Figure 14. Interrupt Acknowledge Timing 
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interrupt vector on the system data bus. The high-order five 
bits of this vector were written to the CTC during the 
programming process; the next two bits are provided by the 
CTC interrupt contro! logic as a binary code that iclentifies 


‘the highest priority channel requesting an interrupt; the 


low-order bit is always zero. 


interrupt Acknowledge Timing. Figure 14 shows 
interrupt acknowledge timing. After an interrupt request, the 
Z80 CPU sends an interrupt acknowledge (M1 and IORQ). 
All channels are inhibited from changing their interrupt 
request status when M1 is active—about two clock cycles 
earlier than {(ORQ. RD is High to distinguish this cycle from 
an instruction fetch. 





The CTC interrupt logic determines the highest priority 
channel requesting an interrupt. if the CTC interrupt enable 
input (IEl) is High, the highest priority interrupting channel 
within the CTC places its interrupt vector on the data bus 
when IORQ goes Low. Two wait states (Twa) are 
automatically inserted at this time to allow the daisy chain to 
stabilize. Additional wait states may be added. 


Return from interrupt Timing. At the end of an interrupt 
service routine the RETI (Return From Interrupt) instruction 
initializes the daisy chain enable lines for proper control of 
nested priority interrupt handling. The CTC decodes the 
2-byte RET! code internally and determines whether it is 
intended for a channel being serviced. Figure 18 shows 
RETI timing. 


lf several Z80 peripherals are in the daisy chain, IEI settles 
active (High) on the chip currently being serviced when the 
opcode ED4¢ is decoded. If the following opcode is 4D4¢, 
the peripheral being serviced is released and its IEO 
becomes active. Additional wait states are allowed. 


Th Tz T3 ar 1 T2 T3 Ta 


1EO = a 


Figure 15. Return From Interrupt Timing 
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a 
ABSOLUTE MAXIMUM RATINGS 


Voltages on Vcc with respect to Vsg ..... ~0.3Vto +7.0V Stresses greater than those listed under Absolute Maximum Ratings may 
Voltages on all inputs with respect cause permanent damage to the device. This is a stress raling only: 

to Vss ~0.3V to Vec+0.3V Operation of the device at any condition above these indicated in the 
Storage Temperature ee tie en a 65 °C to + 150°C operational sections of these specifications is not implied. Exposure to 


absolute maximum rating conditions for extended periods may affect 
Gevice reliability. 


a ee 
STANDARD TEST CONDITIONS 


The characteristics below apply for the following test 


conditions, unless otherwise noted. All voltages are +22 
referenced to GND (OV). Positive current flows into the 
referenced pin. Available operating temperature range is: 2.1K 
@ S=0°C to +70°C, V,. Range FROM OUTPUT 

NMOS: +4.75V $V, < +5.25V UNDER TEST 

CMOS: +4.50V < V,,. < +5.50V a 
M@ E= -40°C to 100°C, +4.50V <V,. $ +5.50V se 

uA 


ranges and product numbers. Refer to the Literature List for 

additional documentation. Package drawings are in the 

Package Information section. = = = 
EEE LS SD 
DC CHARACTERISTICS (Z84C30/CMOS Z80 CTC) 

Voc=5-0OV + 10%, unless otherwise specified 


100 pf 
The Ordering Information section lists package temperature P | 























Symbol Parameter Min Max Unit Condition 
Nee Clock Input Low Voltage -0.3 +0.45 V 
Vn. Clock Input High Voltage Vo-70-6 Vopt0.3 V 
Ve Input High Voltage 22 Vex V 
Veg input Low Voltage ; : -0.3 0.8 V 
Vou Output Low Voltage 0.4 V o=2-OmA 
Veni Output High Voltage 2.4 V loam! 6mA 
Vig Output High Voltage 7 : Vo_-0.8 V log =-2OOpA 
i Input Leakage Current | -10 10 pA Vy=0.4V to Vo. 
he 3-State Output Leakage Current in Float -10 10 pA Vou1=0.4V to V, 
lacs Power Supply Current - 4MHz | 7 [1] mA Voc=5V 
- 6MHZz 8 [1] mA CLK=4,6,8, 1OMHz 
- 8MHz 10 [1] mA Vaz Veg-0.2V 
- 10MHz 12 [1] mA V, =0.2V 
Ls Standby Supply Current 10 pA Vog=5V 
CLK=(0) 
Vae=Vog70-2V 
V,=0.2V — 
lies Dartington Drive Current -1.5 -5.0 mA Voy= 1-SV 


REXT=1.1K ohm 





Note: [1] Measurements made with outputs floating. 





CAPACITANCE 
Symbol Parameter Max Unit 
i 
CLK Clock Capacitance 10 pf 
Cin input Capacitance 10 pf 
Cout Output Capacitance 15 pf 





eg 
Ta = 25°C, f = 1 MHz 
Unmeasured pins returned to ground. 
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AC CHARACTERISTICS (Z84C30/CMOS Z80 CTC) 
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ZCITOo-2 


a. 
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AC CHARACTERISTICS (Z84C30/CMOS Z80 CTC Continued) 


a ys 
Z84C3004* Z84C3006  Z84C3008 284C3010 Note 





No Symbol Parameter Min Max Min Max Min Max Min Max 
SS ep err pt 
1 TcC Clock Cycle Time 250 —s[1] 162 [1] 125 [1] 100 [1] 
2 TwCh Ciock pulse Width (High) 110 DC 65 DC 55. (DE 42 OC 
3 Twi Clock pulse Width (Low) 110 DC 65 DC 55 DC 42 DC 
4 TIC Clock Falt Time 30 20 10 10 
5 TrC Clock Rise Time 30 20 10 10 
6 Th All Hold Times 0 0 0 0 
7 TsCS(C) ICS to Clock Rise Setup Time 160 100 50 35 
8 TsCE(C) /CE to Clock Rise Setup Time 150 100 50 35 
9 TsIOQ{C) /IORQ to Clock Rise Setup Time 115 70 40 35 
10 TsRDX(C) /RD Falt.to Clock Rise Setup Time 115 70 40 35 
11 TdC(DO) Clock Rise to Data Out 200 130 90 90 [2] 
Float Delay 
12 TdRir(DOz) /RD, AORQ rising to Data Outime 50 | 40 40 40 
Float Delay 
13 TsDI(C) Data In to Clock rising set-up 50 40 30 30 
eee 
14 TsM1(C) /M1 to Clock Rise Setup Time 90 70 * $0 40 
15 TdM1i(IEO) /M1 Fall to IEO Fall Delay 
(interrupt Immediately Preceding 190 130 F 90 70 [3] 
/M1 Fall) . 
Sa a rs 
16 TdiO(DIO) AORQ Fall to Data Out Delay 160 110 80 80 {2,6] 
(ANTACK Cycle) 
17 TdIEKIEOF) IE! Fall to 1EO Fall Delay 130 100 70 70 [3] 
18 TdIEKIEOr) {El Rise to IEO Rise Delay 160 110 70 70 [3} 
(After ED Decode) 


i i = 
19 TdC(INT) Ciock Rise to /INT Fall Delay (TcC+140)  (TcC+120) (TcC+100) (TcC+80) [4] 
20 TdCLK(INT) CLK/TRG Rise to /INT Fall Delay | 





TsCTR(C) Satisfied (19)+(26) (19)+(26) (19)+(26) (419)+(26) [5] 
TsCTR(C) Not Satisfied (1)+(419)+(26) (1)+(19)+(26) (1)4+(19)+(26) (1)+(19)+(26) [5] 
21 TcCTR CLK/TRG Cycle Time (2TcC) (2TcC) (2TcC) (2TcC) [5} 
a a a ek eh 
22: TrCTR CLK/TRG Rise Time 50 40 30 30 
23 TICTR CLK/TRG Fall Time 50 40 30 30 
24 TwCTRh CLK/TRG Width (Low) 200 120 90 90 
25 TwCTR! CLK/TRG Width (High) 200 120 90 90 
26 TIsCTR(Cs) CLK/TRG Rise to Clock Rise 210 150 110 90 [5] 
Setup Time for Immediate Count 
27 TsCTR(Ct) CLK/TRG Rise to Clock Rise 210 150 110 90 [4] 


setup Time for Enabting of 
Prescaler On Following Clock Rise 


Tee e—__— NN 
* 4 MHz 284C30 is obsoleted and replaced by 6 MHz 


lea OO ey 
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Z84C30 AC CHARACTERISTICS (Continued) 


rman cr PT Sn a 


Z84C3004: Z84C3006 284C3008 284C3010 Note 





No Symbol Parameter Min Max Min Max Min Max Min = Max 
Ree eee ee a 
28 TdC(ZC/TOr) Clock Rise to ZC/TO Rise Delay 190 140 100 80 

29 TdC(ZC/TOF) Clock Fall to ZC/TO Fall Delay 190 140 100 80 

30 ThRir(D) ICE, HORQ Rise to Data Hold 20 20 10 10 

31 ThC(CS) Clock Rise to /CS Hold 20 20 10 10 


i TT 


* RESET must be active for a minimum of 3 clock cycles. 
Units in Nanoseconds 


Notes: 

[1] TcC = TwCh + TwCi + Tr + TIC. 

{2] Increasing delay by 10nS for each SOpF increase in loading, 200pF max for data lines, and 4 100pF for control fines. 
[3] Increase delay by 2nS for each 10pF increase in loading, 100pF max. 

[4} Timer mode. 

{5] Counter mode. 

[6] 2.5TcT > (N-2)TdIEKIEOF) + TdM1(1EO) + TsIEKIO) + TTL Butter Delay, if any. 


> a A SS SS 


* 4 MHz Z284C30 is obsoleted and replaced by 6 MHz 
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DC CHARACTERISTICS (Z8430/NMOS Z80 CTC) 





Symbol Parameter Min Max Unit Condition 

VILC Clock Input Low Voltage ~0,3¢ + 0.452 V 

Vin Clock Input High Voltage Vec - 0.64 Voc + 0.36 V 

Vit Input Low Voltage | -0.3¢ +0.8a V 

ViH Input High Voltage . +2.28 Vec® V 

VoL Output Low Voltage + 0.44 V lol = 2.0mA 

VOH Output High Voltage +2.4a V log = —250 pA 

Icc Power Supply Current: + 1204 mA 

Ii Input Leakage Current +104 pA Vin = 0.4toVoc 

Lo 3-State Output Leakage Current in Float + 108 pA Vout = 0.4toVoc 

loHD Darlington Drive Current - 1.54 mA ~VoH = 1.5V 
Rext = 3902 


in 
CAPACITANCE | 








Symbol Parameter | Max Unit 
CLK Clock Capacitance 20¢ pf 
Cin | input Capacitance 5¢ pf 
CoutT Output Capacitance 15¢ pf 





Ta = 25°C, f = 1 MHz 
Unmeasured pins returned to ground. 


Parameter Test Status: 


@ Tested 
b Guaranteed 
© Guaranteed by characterization/design 
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AC CHARACTERISTICS (Z8430/NMOS Z80 CTC) 

















20843004 20843006 
Number Symbol Parameter Min Max Min Max -Notest 
1 TeC Clock Cycle Time 250 (1] 162 1] 
2 TwCh Clock Width (High) 105  —- 2000 65 2000 
3 Wo Clock Width (Low) 105 2000 65 2000 
4 TIC Clock Fall Time 30 20 
5 TC Clock Rise Time 30 20 
6 Th All Hold Times 0 0 
7 TsCS(C) CS to Clock t Setup Time 160 100 
8  TsCE(C) CE to Clock t Setup Time 150 100 
9 TsIO(C) IORQ $ to Clock t Setup 
Time 115 70 
10  TsRD(C) RD # to Clock t Setup Time 115 | 70 
11 TdC(DO) Clock t to Data Out Delay 200 130 (2) 
12 TdC(DOz) Clock 4 to Data Out Float 
Delay 110 90 
13. TsDI(C) Data In to Clock t Setup - | 
Time 50 40 
14. TsM1(C) M1 to Clock t Setup Time 90 70 
15 TdMi(IEO) M1 4tolEO 4s Delay 
(Interrupt immediately 
preceding M1) 190 130 {3} 
16 TdiO(DO!)  {IORQ sto Data Out Delay 
(INTA Cycle) 160 110 [2] 
17 TdlEKIEO) §~—sIEI $ to EO 4 Delay 130 100 (3) 
18 TdlEKIEOr) JEIttolEOt Delay 
(After ED Decode) 160 110 (3) 
19  TdC(INT) Clock t to INT $ Delay (1) + 140 (1) 4+ 120 [4,6] 
- 20 TdCLK(INT) CLK/TRGTttoiNTs | 
tsCTR(C) satisfied (19) + (26) (19) + (26) [5.6] 
tsCTR(C) not satisfied (1) + (19) + (26) (1)+(19)+(26) [5.6] 
24 TcCTR , CLK/TRG Cycle Time 2TcC 2TcC (5) 
22 CTR CLK/TRG Rise Time 50 40 
23. ~=TICTR CLK/TRG Fall Time 50 40 
24 + WCTRI CLK/TRG Width (Low) 200 120 
25. WCTRh CLK/TRG Width (High) 200 120 
NOTES: 


[6] Parenthetical numbers reference the table number of a parameter. 
e.g., (1) refers to TcC. 


[1] ToC = TwCh + TwCl + TC + TIC. 

{2] increase delay by 10 ns for each 50 pf increase in loading, 200 pf 
maximum for data lines, and 100 pf for control lines. 3 + 2.5 TcC > (n- 2) TDIEMIEOH + TOM1(IEO) + TsIEIIO) + TTL iouffer 

[3] Increase delay by 2 ns for each 10 pf increase in loading, 100 pf delay, if any. RESET must be active for a minimum of 3 clock cyties. 
MAKE, Units are nanoseconds unless otherwise specified. 

[4] Timer mode 

[5] Counter mode. 
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AC CHARACTERISTICS (Z8430/NMOS Z80 CTC Continued) 


vee 20843004 20843006 
Number Symbol Parameter Min Max Min Max Notest 


ae 





26 TsCTR(Cs) CLK/TRG ft to Clock t Setup 

Time for Immediate | 

Count 210 150 [5] 
27 = TsCTR(Ct) ~—s CLK/TRG f to Clock t Setup | 

Time for enabling of 





Prescater on following 
clock ¢ | 210 150 [4] 
28 TdC(ZC/TOr) ~=Clock t to ZC/TO ¢ Delay -190 140 
29 TdC(ZC/TOf §=Clock + to ZC/TO ¢ Delay 190 140 
NOTES: : . 
[1] TcC = TWCh + WC! + WC + TIC. [6] Parenthetical numbers reference the table number of a parameter. 
(2] Increase delay by 10 ns for each 50 pf increase in loading, 200 pf e.g., (1) refers to TcC. 
maximum for data lines, and 100 pt for control lines. . t 2.5 TeC > (n- 2) TDIEKIEOR + TOM1(IEO) + TsIEKIO) + TTL buffer 
{3} Increase delay by 2 ns for each 10 pf increase in loading. 100 pf delay, if any. RESET must be active for a minimum of 3 clock cycles. 
maximum. Units are nanoseconds unless otherwise specified. 
[4] Timer mode 


[5] Counter mode. 





Gs RP 


98 . a ~ PS018101-0602 





